package com.category.douyijia.model;

import javax.sql.DataSource;

import com.jfinal.kit.PathKit;
import com.jfinal.plugin.activerecord.dialect.MysqlDialect;
import com.jfinal.plugin.activerecord.generator.Generator;
import com.jfinal.plugin.druid.DruidPlugin;
import com.category.douyijia.GlobalConfig;

public class _JFinalGenerator {

	// model 所使用的包名 (MappingKit 默认使用的包名)
		
		static String modelPackageName = "com.category.douyijia.model";
				
		// base model 所使用的包名
		static String baseModelPackageName = modelPackageName + ".base";
				
		// base model 文件保存路径，非 maven 项目使用
		static String baseModelOutputDir = PathKit.getWebRootPath() + "/../src/" + baseModelPackageName.replace('.', '/');
				
		// base model 文件保存路径，maven 项目使用
		// String baseModelOutputDir = PathKit.getWebRootPath() + "/src/main/java/" + baseModelPackageName.replace('.', '/');
				
		// model 文件保存路径 (MappingKit 与 DataDictionary 文件默认保存路径)
		static String modelOutputDir = baseModelOutputDir + "/..";
				
		public static DataSource getDataSource() {
			DruidPlugin druidPlugin = GlobalConfig.createDruidPlugin();
			druidPlugin.start();
			return druidPlugin.getDataSource();
		}
		public static void myGenerator(){
			// 创建生成器
			Generator generator = new Generator(getDataSource(), baseModelPackageName, baseModelOutputDir, modelPackageName, modelOutputDir);
					
			// 配置是否生成备注
			generator.setGenerateRemarks(true);
					
			// 设置数据库方言
			generator.setDialect(new MysqlDialect());
					
			// 设置是否生成链式 setter 方法，强烈建议配置为 false，否则 fastjson 反序列化会跳过有返回值的 setter 方法
			generator.setGenerateChainSetter(false);
					
			// 添加不需要生成的表名
			generator.addExcludedTable("adv");
					
			// 设置是否在 Model 中生成 dao 对象
			generator.setGenerateDaoInModel(false);
					
			// 设置是否生成字典文件
			generator.setGenerateDataDictionary(true);
					
			// 设置需要被移除的表名前缀用于生成modelName。例如表名 "osc_user"，移除前缀 "osc_"后生成的model名为 "User"而非 OscUser
			generator.setRemovedTableNamePrefixes("t_");
					
			// 生成
			generator.generate();
		}
		public static void main(String[] args) {
			myGenerator();
		}
}
